



|          |          |          |        |          |          |
|----------|----------|----------|--------|----------|----------|
| MM       | MM       | PPPPPPPP | IIIIII | NN       | TTTTTTTT |
| MM       | MM       | PPPPPPPP | IIIIII | NN       | TTTTTTTT |
| MMMM     | MMMM     | PP       | PP     | II       | NN       |
| MMMM     | MMMM     | PP       | PP     | II       | NN       |
| MM       | MM       | PP       | PP     | II       | NNNN     |
| MM       | MM       | PP       | PP     | II       | NNNN     |
| MM       | MM       | PPPPPPPP | II     | NN       | NN       |
| MM       | MM       | PPPPPPPP | II     | NN       | NN       |
| MM       | MM       | PP       | II     | NN       | NNNN     |
| MM       | MM       | PP       | II     | NN       | NNNN     |
| MM       | MM       | PP       | II     | NN       | NN       |
| MM       | MM       | PP       | II     | NN       | NN       |
| MM       | MM       | PP       | II     | NN       | TT       |
| MM       | MM       | PP       | II     | NN       | TT       |
| MM       | MM       | PP       | II     | NN       | TT       |
| MM       | MM       | PP       | II     | NN       | TT       |
| MM       | MM       | PP       | II     | NN       | TT       |
| MM       | MM       | PP       | II     | NN       | TT       |
| LL       | LL       | SSSSSSSS | IIIIII | SSSSSSSS |          |
| LL       | LL       | SSSSSSSS | IIIIII | SS       |          |
| LL       | LL       | SS       | IIIIII | SS       |          |
| LL       | LL       | SS       | IIIIII | SS       |          |
| LL       | LL       | SSSSSS   | IIIIII | SS       |          |
| LL       | LL       | SSSSSS   | IIIIII | SS       |          |
| LL       | LL       | SS       | IIIIII | SS       |          |
| LL       | LL       | SS       | IIIIII | SS       |          |
| LLLLLLLL | LLLLLLLL | SSSSSSSS | IIIIII | SSSSSSSS |          |

|     |     |                                                               |
|-----|-----|---------------------------------------------------------------|
| (1) | 61  | DEFINITIONS                                                   |
| (1) | 94  | MPSSMAINIT - INITIALIZE MULTI-PORT MEMORY ADAPTER             |
| (1) | 145 | MPSSINTPRIM - INTERRUPT PRIMARY PROCESSOR                     |
| (1) | 169 | MPSSINTSCND - INTERRUPT SECONDARY PROCESSOR                   |
| (1) | 193 | MPSSPINTSR - PRIMARY PROCESSOR INTERRUPT SERVICE ROUTINE      |
| (1) | 243 | MPSSSINTSR - SECONDARY INTERRUPT SERVICE ROUTINE              |
| (1) | 336 | MPSSINVALID - Relay invalidate request to secondary           |
| (1) | 431 | MPSSBUGCHECK - Relay bugcheck request to secondary and wait   |
| (1) | 461 | MPSSSECBUGCHK - Relay secondary's bugcheck request to primary |

```
0000 1 : Version: 'V04-000'  
0000 2 :  
0000 3 :  
0000 4 :.MCALL MFPR  
0000 5 :.TITLE MPINT - MULTI-PROCESSOR INTERRUPT HANDLER  
0000 6 :.IDENT 'V04-000'  
0000 7 :*****  
0000 8 :* COPYRIGHT (c) 1978, 1980, 1982, 1984 BY  
0000 9 :* DIGITAL EQUIPMENT CORPORATION, MAYNARD, MASSACHUSETTS.  
0000 10 :* ALL RIGHTS RESERVED.  
0000 11 :* THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY BE USED AND COPIED  
0000 12 :* ONLY IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE AND WITH THE  
0000 13 :* INCLUSION OF THE ABOVE COPYRIGHT NOTICE. THIS SOFTWARE OR ANY OTHER  
0000 14 :* COPIES THEREOF MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY  
0000 15 :* OTHER PERSON. NO TITLE TO AND OWNERSHIP OF THE SOFTWARE IS HEREBY  
0000 16 :* TRANSFERRED.  
0000 17 :*  
0000 18 :* THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT NOTICE  
0000 19 :* AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY DIGITAL EQUIPMENT  
0000 20 :* CORPORATION.  
0000 21 :*  
0000 22 :* DIGITAL ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF ITS  
0000 23 :* SOFTWARE ON EQUIPMENT WHICH IS NOT SUPPLIED BY DIGITAL.  
0000 24 :*  
0000 25 :*  
0000 26 :*****  
0000 27 :  
0000 28 :  
0000 29 :++  
0000 30 :  
0000 31 : Facility: Executive , Hardware fault handling  
0000 32 :  
0000 33 : Abstract: This module contains the VAX multiport memory interrupt handler.  
0000 34 :  
0000 35 : Environment: MODE=Kernel, Interrupt  
0000 36 :  
0000 37 : Author: RICHARD I. HUSTVEDT, Creation date: 15-May-1979  
0000 38 :  
0000 39 : Modified by:  
0000 40 :  
0000 41 : V03-007 KDM0026 Kathleen D. Morse 14-Oct-1982  
0000 42 : Conditionalize time-out logic based on debugging switch  
0000 43 : so that taking a breakpoint on the secondary does not  
0000 44 : make the primary turn it off.  
0000 45 :  
0000 46 : V03-006 KDM0018 Kathleen D. Morse 13-Oct-1982  
0000 47 : Add logic to primary code for secondary wait check  
0000 48 : request.  
0000 49 :  
0000 50 : V03-005 KDM0020 Kathleen D. Morse 04-Oct-1982  
0000 51 : Add time-out logic to primary code that requests the  
0000 52 : secondary to do an invalidate of a system space address.
```

|      |    |     |
|------|----|-----|
| 0000 | 53 | :   |
| 0000 | 54 | :   |
| 0000 | 55 | :   |
| 0000 | 56 | :   |
| 0000 | 57 | :   |
| 0000 | 58 | :01 |
| 0000 | 59 | --  |

V03-004 KDM0012 Kathleen D. Morse 20-Sep-1982  
Add second error log buffer and clear MA780 interrupt  
before checking for reason of interrupt.

0000 61 .SBTTL DEFINITIONS  
0000 62 ;  
0000 63 : INCLUDE FILES:  
0000 64 ;  
0000 65 ;  
0000 66 ;  
0000 67 : MACROS:  
0000 68 ;  
0000 69 ;  
0000 70 ;  
0000 71 : EQUATED SYMBOLS:  
0000 72 ;  
0000 73 \$BUGDEF : Bugcheck indicator bit definitions  
0000 74 \$EMBDEF : Error log message buffer definitions  
0000 75 \$EMBDEF SS : Sys srv err log message buffer defs  
0000 76 \$IPLDEF : Interrupt priority levels  
0000 77 \$LCKDEF : Interlock bit definitons  
0000 78 \$MPMDEF : Multiport memory registers  
0000 79 \$MPSDEF : Secondary processor state definitions  
0000 80 \$PCBDEF : Define PCB offsets  
0000 81 \$PHDDEF : Define process header offsets  
0000 82 \$PRDEF : Define processor registers  
0000 83 \$PTEDEF : Define page table entry format  
0000 84 \$RPBDEF : Define reboot parameter block  
0000 85 \$VADEF : Virtual address definition  
0000 86 ;  
00000004 0000 87 MAX\_PORTS = 4 ; Maximum number of ports  
0000 88 ;  
0000 89 ;  
0000 90 : OWN STORAGE:  
0000 91 ;  
00000000 92 .PSECT AEXENONPAGED, LONG ;

0000 94 .SBTTL MPSSMAINIT - INITIALIZE MULTI-PORT MEMORY ADAPTER  
 0000 95 ++  
 0000 96  
 0000 97 : FUNCTIONAL DESCRIPTION:  
 0000 98  
 0000 99 This routine is called at system initialization and after a power  
 0000 100 recovery restart to initialize the port adapter by clearing any  
 0000 101 errors and enabling all interrupts.  
 0000 102  
 0000 103  
 0000 104 : OUPUTS:  
 0000 105  
 0000 106 Any errors in port are cleared and all interrupts are enabled.  
 0000 107  
 0000 108 --  
 0000 109 MPSSMAINIT:::  
 54 0000'CF 3F BB 0000 110 PUSHR #^M<R0,R1,R2,R3,R4,R5> Save registers  
 00400000 BF DO 0002 111 MOVL W^MPSSAL\_MPMBASE,R4 Get base of MPM registers  
 64 DO 0007 112 MOVL #MPMSM\_CSR PU,- Clear any power-up status  
 04 A4 FF000001 8F DO 000D 113 MOVL #MPMSL\_CSR(R4)  
 DO 000E 114 MOVL #MPMSM\_CR\_ERRS!- Clear any port errors and  
 000F 115 MOVL #MPMSM\_CR\_MIE,- Enable master interrupt  
 DO 0016 116 MOVL #MPMSM\_SR\_SS!- Clear any status errors and  
 0017 117 MOVL #MPMSM\_SR\_IDL!- disable error interrupts  
 0017 118  
 0017 119  
 0017 120  
 0017 121  
 0017 122  
 08 A4 D000E000 8F DO 0017 123  
 50 0C A4 DO 001E 124 MOVL MPMSL\_INV(R4),R0 Get invalidation register  
 50 800FFFFF 8F CA 0022 125 BICL #^C<MPMSM\_INV\_STADR>,R0 Clear all but starting address  
 0C A4 50 01 C9 0029 126 ASSUME MPMSV\_INV\_ID EQ 0 Cached nexus id's start at 0  
 DO 002E 127 BISL3 #120,R0/MPMSL\_INV(R4) Set cpu (nexus 0) as cached  
 DO 002F 128 MOVL #MPMSM\_ERR\_ELR!- Clear any errors  
 10 A4 90000000 8F DO 002F 129  
 00000400 8F DO 0036 130 MOVL #MPMSM\_CSR1\_MIA,- Clear any error  
 18 A4 DO 003C 131 MOVL #MPMSL\_CSR1(R4)  
 1C A4 D4 003E 132 CLRL MPMSL\_MR(R4)  
 50 64 DO 0041 133 MOVL MPMSL\_CSR(R4),R0 Clear any diagnostic settings  
 50 00 EF 0044 134 EXTZV #MPMSV\_CSR\_PORT,- Get CSR register  
 50 50 02 0046 135 MULL #MPMSV\_CSR\_PORT,R0,R0 Get port number  
 50 04 C4 0049 136 ADDL #MAX\_PORTS,R0 Compute interrupt enable bit #  
 50 10 C0 004C 137 ASHL #MPMSV\_IIE\_CTL,R0  
 24 A4 OF 50 78 004F 138 R0,#^XF,MPMSL\_IIE(R4) Enable interport interrupts  
 0054 140  
 3F BA 0054 141 POPR #^M<R0,R1,R2,R3,R4,R5>  
 05 0056 142 RSB  
 0057 143  
 : Restore registers  
 : Return

0057 145 .SBTTL MPSSINTPRIM - INTERRUPT PRIMARY PROCESSOR  
0057 146 ++  
0057 147 : FUNCTIONAL DESCRIPTION:  
0057 148 :  
0057 149 : MPSSINTPRIM is called to cause an interrupt to the primary processor.  
0057 150 :  
0057 151 : CALLING SEQUENCE:  
0057 152 :  
0057 153 : BSB/JSB MPSSINTPRIM  
0057 154 :  
0057 155 : INPUT PARAMETERS:  
0057 156 :  
0057 157 : NONE  
0057 158 :  
0057 159 : OUTPUT PARAMETERS:  
0057 160 :  
0057 161 : NONE  
0057 162 :--  
0057 163 :  
0057 164 MPSSINTPRIM:  
0057 165 MOVL W^MPSSGL\_PRIMSKT, @W^MPSSGL\_MPMLIR ; Trigger primary interrupt  
05 005E 166 RSB ; And return  
005F 167

005F 169 .SBTTL MPSSINTSCND - INTERRUPT SECONDARY PROCESSOR  
005F 170 ++  
005F 171 : FUNCTIONAL DESCRIPTION:  
005F 172 : MPSSINTSCND is called to interrupt the secondary processor.  
005F 173 :  
005F 174 : CALLING SEQUENCE:  
005F 175 :  
005F 176 : BSB/JSB MPSSINTSCND  
005F 177 :  
005F 178 : INPUT PARAMETERS:  
005F 179 :  
005F 180 : NONE  
005F 181 :  
005F 182 :  
005F 183 : OUTPUT PARAMETERS:  
005F 184 :  
005F 185 : NONE  
005F 186 :--  
005F 187 :  
005F 188 MPSSINTSCND:  
005F 189 MOVL W^MPSSGL\_SCNDMSKT,AW^MPSSGL\_MPMIIR ; Trigger secondary interrupt  
05 0066 190 RSB ; And return  
0067 191

0067 193 .SBTTL MPSSPINTSR - PRIMARY PROCESSOR INTERRUPT SERVICE ROUTINE  
 0067 194 :++  
 0067 195 : FUNCTIONAL DESCRIPTION:  
 0067 196 :  
 0067 197 : MPSSPINTSR is entered via the interrupt vector for the MA780 in  
 0067 198 : the primary processor in response to a call to MPSSINTPRIM.  
 0067 199 :--  
 0067 200 :  
 0067 201 :  
 0067 202 :.ALIGN LONG  
 0068 203 MPSSPINTSR::: Primary interrupt service routine  
 0068 204 PUSHL R0 : Save R0  
 0068 205 MOVL W^MPSSAL\_MPMBASE,R0 : Get base of MPM registers  
 0068 206 MOVL W^MPSSGL\_PRIMSKC,MPMSL\_IIR(R0) : Clear pending interrupt  
 0068 207 POPL R0 : Restore R0  
 0068 208 BBCCI #MPSSV\_SECBUGCHK,W^MPSSGL\_SECREQFLG,10\$ ; Br if no bugchk to do  
 0068 209 .LIST MEB  
 0068 210 BUG\_CHECK MPBADMCK,FATAL ; Jump to bugcheck code  
 0068 211 .WORD ^XFEFF  
 0068 212 .IIF IDN <FATAL>,<FATAL>,.WORD BUGS\_MPBADMCK!4  
 0068 213 MPSSGW\_BUGCHKCOD == .-2 : Location for secondary to place the  
 0068 214 : type of bugcheck it is requesting  
 0068 215 :.NLIST MEB  
 0068 216 :  
 0068 217 :  
 0068 218 :20\$: BBCCI #MPSSV\_SECERRLOG,W^MPSSGL\_SECREQFLG,50\$ ; Br if no errlog to do  
 0068 219 :  
 0068 220 :  
 0068 221 :  
 0068 222 :  
 0068 223 :  
 0068 224 :  
 0068 225 :  
 0068 226 :  
 0068 227 :  
 0068 228 :30\$: BBCCI #MPSSV\_ERLBUF1,W^MPSSGL\_ERLBUFIND,30\$ ; Br if no entry in buf 1  
 0068 229 :  
 0068 230 :  
 0068 231 :40\$: POPR #^M<R0,R1,R2,R3,R4,R5> ; Restore registers  
 0068 232 :  
 0068 233 : Nothing to be done at device IPL. This is either a spurious  
 0068 234 : interrupt, or an event flag wait check request from the secondary,  
 0068 235 : or a legitimate reschedule request from the secondary. Cause the  
 0068 236 : reschedule software interrupt and check for requested work at that  
 0068 237 : IPL.  
 0068 238 :  
 0068 239 :50\$: SOFTINT #5 ; Request IPL 5 interrupt  
 0068 240 :  
 0068 241 : REI ; And return

00D2 243 .SBTTL MPSSINTSR - SECONDARY INTERRUPT SERVICE ROUTINE  
 00D2 244 ++  
 00D2 245 FUNCTIONAL DESCRIPTION:  
 00D2 246  
 00D2 247 MPSSINTSR is entered in response to an interrupt on the secondary  
 00D2 248 processor. The interrupt was sent for one of the following reasons:  
 00D2 249  
 00D2 250 1) An AST was sent to the process currently  
 00D2 251 running on the secondary  
 00D2 252 (Primary processor is executing QAST.)  
 00D2 253  
 00D2 254 2) A system space address was invalidated by  
 00D2 255 the primary processor  
 00D2 256 (Primary processor is executing FREWSL or PAGEFAULT.)  
 00D2 257  
 00D2 258 3) The primary wants to bugcheck.  
 00D2 259  
 00D2 260 The secondary processor, not knowing which reason the interrupt  
 00D2 261 was sent, does the appropriate work to handle all the reasons.  
 00D2 262 (Since the code is small, there is no need to figure out the real  
 00D2 263 reason for the interrupt.) The following list corresponds to the  
 00D2 264 work done to handle the above conditions causing an interrupt:  
 00D2 265  
 00D2 266 1) The ASTLVL for the process currently running  
 00D2 267 on the secondary is updated  
 00D2 268  
 00D2 269 2) An invalidate is done for the system space  
 00D2 270 address indicated by MPSSGL\_INVALID  
 00D2 271  
 00D2 272 3) First, fold up the current process.  
 00D2 273 Second, load the loop address into the RPB.  
 00D2 274 Third, acknowledge the bugcheck request.  
 00D2 275 Fourth, halt to turn off mapping. Execution continues  
 00D2 276 if restart is enabled, by the console program executing  
 00D2 277 RESTAR.CMD.  
 00D2 278 :--  
 00D2 279  
 00D2 280 .ALIGN LONG  
 00D4 281 MPSSINTSR:: : Secondary interrupt service routine  
 00D4 282 PUSHL R0 : Save R0  
 00D6 283 MOVL W^MPSSAL\_MPMBASE, R0 : Get base of MPM registers  
 00DB 284 MOVL W^MPSSGL\_SCNDMSK, MPM\$L\_IIR(R0); Clear pending interrupt  
 00E1 285 POPL R0 : Restore R0  
 00E4 286 BBSI #LCK\$V\_INTERLOCK,W^MPSSGL\_INTERLOCK,5S ; Flush cache queue  
 00EA 287 5S: BBS #BUG\$V\_BUGCHK,W^MPSSGL\_BUGCHECK,10S ; Br if bugcheck requested  
 00F0 288 BBS #MPSSV\_STOPREQ,W^MPSSGE\_STOPFLAG,50S ; Br if STOP/CPU requested  
 00F6 289 : Update the ASTLVL for the process currently running on the secondary.  
 00F6 290  
 00F6 291 : Save R0  
 00F6 292 PUSHL R0 : Get current PCB address  
 00F8 293 MOVL W^MPSSGL\_CURPCB, R0 : Get PHD address  
 00FD 294 MOVL PCBSL\_PHD(R0), R0 : And fetch ASTLVL  
 0101 295 MOVB PHDSB\_ASTLVL(R0), R0 : Update current value  
 0106 296 MTPR R0,#PRS\_ASTLVL  
 0109 297  
 0109 298 : Invalidate the system space address that is contained in MPSSGL\_INVALID.  
 0109 299 :

0000'CF 00 0109 300 INVALID W^MPSSGL\_INVALID ; Invalidate requested page  
 04 0000'CF D4 010E 301 CLRL W^MPSSGL\_INVALID ; And acknowledge it  
 50 BED0 0112 302 POPL R0 ; Restore R0  
 02 0115 303 REI ; And continue

0116 304  
 0116 305 : Primary processor has requested a bugcheck. The secondary must fold  
 0116 306 : up the process it is running and loop quietly in a safe place out of  
 0116 307 : the way of the primary.  
 0116 308

00 0000'CF 00 E6 0116 310: BBSSI #LCKSV\_INTERLOCK,W^MPSSGL\_INTERLOCK,20\$ ; Flush cache queue  
 04 0000'CF D1 011C 311: CMPL W^MPSSGL\_STATE,#MPSSK\_EXECSTATE ; Was LDPCCTX done?  
 01 12 0121 312: BNEQ 30\$ : Br if not done, don't do SVPCTX  
 07 0123 313: SVPCTX  
 50 00000000'GF D0 0124 314: MOVL G^EXESGL\_RPB,R0 ; Get address of RPB  
 60 00000100'8F C1 012B 315: ADDL3 #RPBSB\_WAIT,RPBSL\_BASE(R0),RPBSL\_BUGCHK(R0) ; Load loop adr  
 0000'CF 06 D0 0135 316: MOVL #MPSSK\_STOPSTATE,W^MPSSGL\_STATE ; Indicate processor not active  
 00 0000'CF 01 E6 013A 317: BBSSI #BUGSV\_ACK1,W^MPSSGL\_BUGCHECK,40\$ ; Acknowledge bugcheck request  
 00 0140 318: HALT ; This halt causes the secondary to  
 0141 319 : start executing RESTAR.CMD on the  
 0141 320 : console device if restart is enabled.  
 0141 321 :  
 0141 322 : A STOP/CPU was issued. The secondary must return its current process.  
 0141 323 : If any, load a wait loop into the RPB, and halt.  
 0141 324 :

00 0000'CF 00 E6 0141 325: BBSSI #LCKSV\_INTERLOCK,W^MPSSGL\_INTERLOCK,60\$ ; Flush cache queue  
 04 0000'CF D1 0147 326: CMPL W^MPSSGL\_STATE,#MPSSK\_EXECSTATE ; Is there a current process?  
 06 12 014C 327: BNEQ 70\$ : Br if no current state to save  
 07 014E 328: SVPCTX ; Save state of current process

50 0000'CF 02 D0 014F 329: MOVL #MPSSK\_DROPSTATE,W^MPSSGL\_STATE ; Primary must take process back  
 60 00000000'GF D0 0154 330: MOVL G^EXESGL\_RPB,R0 ; Get address of RPB  
 00000100'8F C1 015B 331: ADDL3 #RPBSB\_WAIT,RPBSL\_BASE(R0),RPBSL\_BUGCHK(R0) ; Load loop adr  
 0000'CF D4 0165 332: CLRL W^MPSSGL\_INVALID ; Indicate no invalidate to wait on  
 00 0000'CF 01 E6 0169 333: BBSSI #MPSSV\_STOPACK1,W^MPSSGL\_STOPFLAG,80\$ ; Acknowledge STOP request  
 00 016F 334: HALT ; Stop the secondary

0170 336 .SBTTL MPSSINVALID - Relay invalidate request to secondary  
 0170 337 ++  
 0170 338 : FUNCTIONAL DESCRIPTION:  
 0170 340 : MPSSINVALID relays a translation buffer invalidate request to  
 0170 341 : the secondary processor and waits for acknowledgement before  
 0170 342 : proceeding. Since P0 pages are only referenced by the processor  
 0170 343 : currently executing a process, only system pages need to be  
 0170 344 : invalidated by both the primary and secondary processors at  
 0170 345 : the same time.  
 0170 346 :  
 0170 347 : This code is hooked into the pagefault exception handling code.  
 0170 348 :  
 0170 349 :--  
 0170 350 :  
 0170 351 MPSSINVALID::  
 03 A3 84 8F 8A 0170 352 BICB #<PTE\$M\_VALID!PTE\$M MODIFY> a-24,3(R3); Clear valid and modify  
 0175 353 : (Replaced instruction)  
 38 52 1F E1 0175 354 INVALID R2 : Invalidate for primary processor  
 00 0000'CF 00 0175 355 BBC #VASV\_SYSTEM,R2,60\$ : Only invalidate for system space  
 05 0000'CF D1 017C 356 ASSUME MPSSK\_STOPSTATE GT MPSSK\_INITSTATE  
 0000'CF 52 D0 0182 357 10\$: BBSSI #LCKSV\_INTERLOCK,W^MPSSGE\_INTERLOCK,10\$ ; Flush cache queue  
 2B 18 0187 358 CMPL W^MPSSGL\_STATE,#MPSSK\_INITSTATE ; Secondary active?  
 0189 359 BGEQ 60\$ 60\$ : Br if no, secondary not responding  
 018E 360 MOVL R2,W^MPSSGL\_INVALID : Set address to invalidate  
 018E 361 :  
 018E 362 .IF DF\_MPPFMSWT  
 018E 363 INCL W^PFMSL\_CNT\_INVAL : Add one to perf meas invalidate ctr  
 018E 364 .ENDC :  
 018E 365 :  
 FECE 30 018E 366 BSBW MPSSINTSCND : Interrupt secondary processor  
 5A 00E4E1C0 8F 0191 367 DD PUSHL R10 : Save R10  
 02 5A F4 0193 368 MOVL #15000000,R10 : Initialize time-out counter  
 019A 369 20\$: SOBGEQ R10,30\$ : Repeat loop, waiting for secondary ack  
 019D 370 :  
 1B 11 019D 371 .IF NDF\_MPDBGSWT  
 019F 372 BRB 70\$ : Go log failure and turn off secondary  
 019F 373 .IFF MPDBGSWT DEFINED :  
 019F 374 BRB 30\$ : Don't turn off secondary, just loop  
 019F 375 : if debugging as breakpoints would  
 019F 376 : cause the secondary to get turned off  
 019F 377 .ENDC :  
 019F 378 :  
 00 0000'CF 00 E6 019F 379 30\$: BBSSI #LCKSV\_INTERLOCK,W^MPSSGL\_INTERLOCK,40\$ ; Flush cache queue  
 0000'CF D5 01A5 380 40\$: TSTL W^MPSSGL\_PFAILTIM : Has secondary powerfailed?  
 06 12 01A9 381 BNEQ 50\$ : Br if yes, don't wait for him  
 01AB 382 :  
 01AB 383 .IF DF\_MPPFMSWT  
 01AB 384 INCL W^PFMSL\_CNT\_IWAIT : Inc perf meas invalidate loop counter  
 01AB 385 .ENDC :  
 01AB 386 :  
 0000'CF D5 01AB 387 TSTL W^MPSSGL\_INVALID : Acknowledged yet?  
 E9 12 01AF 388 BNEQ 20\$ : No, continue waiting  
 5A 8E D0 0181 389 50\$: POPL R10 : Restore R10  
 00000000'GF 17 01B4 390 60\$: JMP G^MMGSFRE\_TRYSKIP : Continue with page fault  
 01BA 391 :  
 01BA 392 :

01BA 393 : The secondary did not acknowledge the invalidate request. Therefore,  
 01BA 394 : the primary assumes it has died. A message is placed in the error log  
 01BA 395 : and an indicator is incremented showing that this failure occurred.  
 01BA 396 : Then the multi-processing code is unhooked from the running system,  
 01BA 397 : making the primary ignore any further activity from the secondary.  
 01BA 398 : The pool space containing the multi-processing code is left untouched  
 01BA 399 : just in case the secondary is eventually resurrected and tries to  
 01BA 400 : continue executing. If this happens, some unexpected interrupt will  
 01BA 401 : probably be logged by the primary but nothing will have been lost.  
 01BA 402 : except whatever process the secondary may have been running.  
 01BA 403 :  
 01BA 404 : This design allows a gradual degradation of the system to a single  
 01BA 405 : processor 11/780, instead of forcing a bugcheck.  
 01BA 406 :

|                       |      |      |     |       |        |                                                        |                                          |
|-----------------------|------|------|-----|-------|--------|--------------------------------------------------------|------------------------------------------|
| 0000'CF               | D6   | 01BA | 407 | 70\$: | INCL   | W^MPSSGL_INV_NACK                                      | ; Indicate secondary did not acknowledge |
| 3F                    | BB   | 01BE | 408 |       | PUSHR  | #^M<R0,RT,R2,R3,R4,R5>                                 | ; Save registers for MOVC                |
| 51 00'8F              | 9A   | 01C0 | 409 |       | MOVZBL | #MPSSC_INV_NACK,R1                                     | ; Size of ASCII message text             |
| 51 15                 | C0   | 01C4 | 410 |       | ADDL   | #<EMBSR_SS_LENGTH+3>,R1                                | ; Add in overhead for message            |
| 51 03                 | CA   | 01C7 | 411 |       | BICL   | #3,R1                                                  | ; Buffer size modulo 4                   |
| 00000000'GF           | 16   | 01CA | 412 |       | JSB    | G^ERL\$ALLOCEMB                                        | ; Allocate error log buffer              |
| 1E 50                 | E9   | 01D0 | 413 |       | BLBC   | R0,80\$                                                | ; If failure, just unhook MP code        |
| 04 A2 27              | B0   | 01D3 | 414 |       | MOVW   | #EMBS_C_SS,EMBSW_SS_ENTRY(R2)                          | ; Set type of error log message          |
| 10 A2 0000'8F         | B0   | 01D7 | 415 |       | MOVW   | #MPSSC_INV_NACK,EMBSW_SS_MSGSZ(R2)                     | ; Set size of ASCII text msg             |
| 12 A2 0000'CF 0000'8F | 28   | 01DF | 416 |       | PUSHL  | R2                                                     | ; Save buffer address                    |
| 52 8ED0               | 01E8 | 417  |     |       | MOVC   | #MPSSC_INV_NACK,W^MPSS\$T_INV_NACK,EMBSB_SS_MSGTXT(R2) | ; Msg txt                                |
| 00000000'GF           | 16   | 01EB | 418 |       | POPL   | R2                                                     | ; Restore buffer address                 |
|                       |      | 419  |     |       | JSB    | G^ERL\$RELEASEMB                                       | ; Release error log buffer               |
|                       |      | 420  |     |       |        |                                                        |                                          |
|                       |      | 421  |     |       |        |                                                        |                                          |
|                       |      | 422  |     |       |        |                                                        |                                          |
|                       |      | 423  |     |       |        |                                                        |                                          |
|                       |      | 424  |     |       |        |                                                        |                                          |
| 00 00000000'EF 00     | E6   | 01F1 | 425 | 80\$: | BBSSI  | #MPSSV_STOPREQ_MPSSGL_STOPFLAG,90\$                    | ; Indic primary forced a stop            |
| 5A 00000000'GF        | D0   | 01F9 | 426 | 90\$: | MOVL   | G^EXESGL_MP,R10                                        | ; Get address of MP code                 |
| FDFD'                 | 30   | 0200 | 427 |       | BSBW   | W^MPSSUNHOOK                                           | ; Unhook MP code from VMS code           |
| 043F 8F               | BA   | 0203 | 428 |       | POPR   | #^M<R0,R1,R2,R3,R4,R5,R10>                             | ; Restore registers                      |
| FFAA                  | 31   | 0207 | 429 |       | BRW    | 60\$                                                   | ; Continue with normal VMS code          |

: Now unhook the multi-processing code and restore the system to  
 : a single processor 11/780, vanilla VMS system.

020A 431 .SBTTL MPSSBUGCHECK - Relay bugcheck request to secondary and wait  
020A 432 ++  
020A 433 : FUNCTIONAL DESCRIPTION:  
020A 434 :  
020A 435 : MPSSBUGCHECK makes sure that the secondary is out of the way before  
020A 436 : the primary proceeds with the bugcheck logic. It sets a flag to  
020A 437 : indicate a bugcheck is requested. Then interrupts the secondary to  
020A 438 : make it notice the flag. The primary then waits for the secondary  
020A 439 : to acknowledge the bugcheck request.  
020A 440 :  
020A 441 : ENVIRONMENT:  
020A 442 :  
020A 443 : Executed by the primary processor.  
020A 444 : IPL = 31  
020A 445 :  
020A 446 :--  
020A 447 :  
020A 448 MPSSBUGCHECK::  
00 0000'CF 00 E6 020A 449 BBSI #BUGSV\_BUGCHK,W^MPSSGL\_BUGCHECK,10\$ ; Indicate bugcheck request  
05 0000'CF D1 0210 450 ASSUME MPSSK\_STOPSTATE GT MPSSK\_INITSTATE  
1B 18 0215 451 10\$: CMPL W^MPSSGL\_STATE,#MPSSK\_INITSTATE ; Is secondary active?  
00 0000'CF 00 E6 0217 452 BGEQ 50\$ : Br on not active, don't request bugchk  
FE3F 30 021D 453 BBSI #BUGSV\_BUGCHK,W^MPSSGL\_BUGCHECK,20\$ ; Indicate bugcheck request  
50 00E4E1C0 8F D0 0220 454 20\$: BSBW W^MPSSINTSCND : Interrupt secondary to notice request  
02 0000'CF 01 E7 0227 455 MOVL #15000000,RO : Wait a significant amount of time  
03 11 022D 456 30\$: BBCCI #BUGSV\_ACK1,W^MPSSGL\_BUGCHECK,40\$ ; Wait for secondary acknowledge  
F5 50 F4 022F 457 BRB 50\$ : Secondary done, continue with bugchk  
00000000'9F 17 0232 458 40\$: SOBGEQ RO,30\$ : Repeat as secondary not acknowledged  
459 50\$: JMP 2#EXESINIBOOTADP : Continue with normal bugcheck code

0238 461 .SBTTL MPSSSECBUGCHK - Relay secondary's bugcheck request to primary  
 0238 462 :++  
 0238 463 : FUNCTIONAL DESCRIPTION:  
 0238 464 :  
 0238 465 : MPSSSECBUGCHK is executed when the secondary processor wants to initiate  
 0238 466 : a bugcheck. It sets a flag indicating a bugcheck is requested and  
 0238 467 : interrupts the primary to make it notice the flag. The secondary then  
 0238 468 : waits for the primary to interrupt it with the actual bugcheck request  
 0238 469 : by executing a self-branch.  
 0238 470 :  
 0238 471 : INPUTS:  
 0238 472 :  
 0238 473 : The return address pushed on the stack by calling this routine  
 0238 474 : is the address of the bugcheck code being requested.  
 0238 475 :  
 0238 476 : OUTPUTS:  
 0238 477 :  
 0238 478 : None  
 0238 479 :  
 0238 480 : ENVIRONMENT:  
 0238 481 :  
 0238 482 : Executed by the secondary processor.  
 0238 483 :  
 0238 484 :--  
 0238 485 :  
 0238 486 MPSSSECBUGCHK::  
 00FC C0 FE42 CF 00 BE B0 0238 487 MOVW A(SP),W^MPSSGW\_BUGCHKCOD ; Set type of bugcheck requested  
 50 00000000'GF D0 023E 488 MOVL G^EXE\$GL\_RPB,R0 ; Get address of RPB  
 60 00000100 8F C1 0245 489 ADDL3 #RPBSB\_WAIT,RPBSL\_BASE(R0),RPBSL\_BUGCHK(R0) ; Load loop adr  
 00 0000'CF 00 E6 0252 490 SETIPL #IPL\$ SYNCH ; Lower IPL, enabling inter-proc intrpt  
 FDFC 30 0258 491 BBSSI #MPSSV\_SECBUGCHK,W^MPSSGL\_SECREQFLG,10\$ ; Set request flag  
 00 0000'CF 00 E6 025B 492 10\$: BSBW W^MPSSINTPRIM ; Interrupt primary processor  
 05 0000'CF 00 D1 0261 493 BBSSI #LCK\$V\_INTERLOCK,W^MPSSGL\_INTERLOCK,20\$ ; Flush cache queue  
 02 18 0266 494 20\$: CMPL W^MPSSGL\_STATE,#MPSSK\_INITSTATE ; Secondary active?  
 FE 11 0268 495 BGEQ 40\$ ; Br if not active  
 026A 496 30\$: BRB 30\$ ; Wait for interrupt from primary to  
 00 026A 497 handle the bugcheck  
 026B 498 40\$: HALT ; This halt causes the secondary to  
 026B 499 start executing RESTART.CMD on the  
 026B 500 console device if restart is enabled.  
 026B 501  
 026B 502 .END

|                  |            |       |                  |            |    |    |
|------------------|------------|-------|------------------|------------|----|----|
| BUGSV_ACK1       | = 00000001 |       | MPSSGL_INV_NACK  | *****      | X  | 02 |
| BUGSV_BUGCHK     | = 00000000 |       | MPSSGL_MPMLIR    | *****      | X  | 02 |
| BUGS_MPBADMCK    | *****      | X 02  | MPSSGL_PFAILTIM  | *****      | X  | 02 |
| EMBSB_SS_MSGTXT  | = 00000012 |       | MPSSGL_PRIMSKC   | *****      | X  | 02 |
| EMBSC_HD_LENGTH  | = 00000010 |       | MPSSGL_PRIMSKT   | *****      | X  | 02 |
| EMBSC_SS         | = 00000027 |       | MPSSGL_SCNDMSKC  | *****      | X  | 02 |
| EMBSK_SS_LENGTH  | = 00000012 |       | MPSSGL_SCNDMSKT  | *****      | X  | 02 |
| EMBSL_HD_SID     | = 00000000 |       | MPSSGL_SECREQFLG | *****      | X  | 02 |
| EMBSW_HD_ENTRY   | = 00000004 |       | MPSSGL_STATE     | *****      | X  | 02 |
| EMBSW_SIZE       | = FFFFFFFC |       | MPSSGL_STOPFLAG  | *****      | X  | 02 |
| EMBSW_SS_ENTRY   | = 00000004 |       | MPSSGW_BUGCHKCOD | = 00000080 | RG | 02 |
| EMBSW_SS_MSGSZ   | = 00000010 |       | MPSSINTPRIM      | 00000057   | RG | 02 |
| ERL\$ALLOCEMB    | *****      | X 02  | MPSSINTSCND      | 0000005F   | RG | 02 |
| ERL\$RELEASEMB   | *****      | X 02  | MPSSINVALID      | 00000170   | RG | 02 |
| EXESGL_MP        | *****      | X 02  | MPSSK_DROPSTATE  | = 00000002 |    |    |
| EXESGL_RPB       | *****      | X 02  | MPSSK_EXECSTATE  | = 00000004 |    |    |
| EXESINIBOOTADP   | *****      | X 02  | MPSSK_INITSTATE  | = 00000005 |    |    |
| IPL\$SYNCH       | = 00000008 |       | MPSSK_STOPSTATE  | = 00000006 |    |    |
| LCKSV_INTERLOCK  | = 00000000 |       | MPSSMAINIT       | 00000000   | RG | 02 |
| MAX_PORTS        | = 00000004 |       | MPSSPINTSR       | 00000068   | RG | 02 |
| MMG\$FRE_TRYSKIP | *****      | X 02  | MPSSSECBUGCHK    | 00000238   | RG | 02 |
| MPMSL_CR         | = 00000004 |       | MPSSSINTSR       | 000000D4   | RG | 02 |
| MPMSL_CSR        | = 00000000 |       | MPSST_INV_NACK   | *****      | X  | 02 |
| MPMSL_CSR1       | = 00000018 |       | MPSSUNHOOK       | *****      | X  | 02 |
| MPMSL_ERR        | = 00000010 |       | MPSSV_ERLBUF1    | = 00000000 |    |    |
| MPMSL_IIE        | = 00000024 |       | MPSSV_ERLBUF2    | = 00000001 |    |    |
| MPMSL_IIR        | = 00000020 |       | MPSSV_SECBUGCHK  | = 00000000 |    |    |
| MPMSL_INV        | = 0000000C |       | MPSSV_SECCERRLOG | = 00000001 |    |    |
| MPMSL_MR         | = 0000001C |       | MPSSV_STOPACK1   | = 00000001 |    |    |
| MPMSL_SR         | = 00000008 |       | MPSSV_STOPREQ    | = 00000000 |    |    |
| MPMSM_CR_ERRS    | = FF000000 |       | PCBSL_PHD        | = 0000006C |    |    |
| MPMSM_CR_MIE     | = 00000001 |       | PHDSB_ASTLVL     | = 000000CF |    |    |
| MPMSM_CSR1_MIA   | = 00000400 |       | PRS_ASTLVL       | = 00000013 |    |    |
| MPMSM_CSR_PU     | = 00400000 |       | PRS_IPL          | = 00000012 |    |    |
| MPMSM_ERR_ELR    | = 10000000 |       | PRS_SIRR         | = 00000014 |    |    |
| MPMSM_ERR_IMP    | = 80000000 |       | PRS_TBIS         | = 0000003A |    |    |
| MPMSM_INV_STADR  | = 7FF00000 |       | PTESM MODIFY     | = 04000000 |    |    |
| MPMSM_SR_ACA     | = 80000000 |       | PTESM_VALID      | = 80000000 |    |    |
| MPMSM_SR_AGP     | = 10000000 |       | RPBSB_WAIT       | = 00000100 |    |    |
| MPMSM_SR_IDL     | = 00004000 |       | RPBSL_BASE       | = 00000000 |    |    |
| MPMSM_SR_IT      | = 00008000 |       | RPBSL_BUGCHK     | = 000000FC |    |    |
| MPMSM_SR_MXF     | = 40000000 |       | VASV_SYSTEM      | = 0000001F |    |    |
| MPMSM_SR_SS      | = 00002000 |       |                  |            |    |    |
| MPMSV_CSR_PORT   | = 00000002 |       |                  |            |    |    |
| MPMSV_CSR_PORT   | = 00000000 |       |                  |            |    |    |
| MPMSV_IIE_CTL    | = 00000010 |       |                  |            |    |    |
| MPMSV_INV_ID     | = 00000000 |       |                  |            |    |    |
| MPSSAL_ERLBUF1   | *****      | X 02  |                  |            |    |    |
| MPSSAL_ERLBUF2   | *****      | X 02  |                  |            |    |    |
| MPSSAL_MPMBASE   | *****      | X 02  |                  |            |    |    |
| MPSSBUGCHECK     | 0000020A   | RG 02 |                  |            |    |    |
| MPSSC_INV_NACK   | *****      | X 02  |                  |            |    |    |
| MPSSGE_BUGCHECK  | *****      | X 02  |                  |            |    |    |
| MPSSGL_CURPCB    | *****      | X 02  |                  |            |    |    |
| MPSSGL_ERLBUFIND | *****      | X 02  |                  |            |    |    |
| MPSSGL_INTERLOCK | *****      | X 02  |                  |            |    |    |
| MPSSGL_INVALID   | *****      | X 02  |                  |            |    |    |

```
! Psect synopsis !
-----
```

## PSECT name

```
-----  
ABS .  
$ABSS  
AEXENONPAGED
```

| Allocation                                                                      | PSECT No. | Attributes |
|---------------------------------------------------------------------------------|-----------|------------|
| 00000000 ( 0.) 00 ( 0.) NOPIC USR CON ABS LCL NOSHR NOEXE NORD NOWRT NOVEC BYTE |           |            |
| 00000000 ( 0.) 01 ( 1.) NOPIC USR CON ABS LCL NOSHR EXE RD WRT NOVEC BYTE       |           |            |
| 0000026B ( 619.) 02 ( 2.) NOPIC USR CON REL LCL NOSHR EXE RD WRT NOVEC LONG     |           |            |

```
! Performance indicators !
-----
```

## Phase

| Phase                  | Page faults | CPU Time    | Elapsed Time |
|------------------------|-------------|-------------|--------------|
| Initialization         | 32          | 00:00:00.10 | 00:00:01.15  |
| Command processing     | 131         | 00:00:00.85 | 00:00:04.28  |
| Pass 1                 | 288         | 00:00:08.89 | 00:00:28.05  |
| Symbol table sort      | 0           | 00:00:01.20 | 00:00:01.96  |
| Pass 2                 | 109         | 00:00:02.14 | 00:00:06.64  |
| Symbol table output    | 12          | 00:00:00.09 | 00:00:00.38  |
| Psect synopsis output  | 2           | 00:00:00.02 | 00:00:00.23  |
| Cross-reference output | 0           | 00:00:00.00 | 00:00:00.00  |
| Assembler run totals   | 576         | 00:00:13.29 | 00:00:42.70  |

The working set limit was 1500 pages.

47795 bytes (94 pages) of virtual memory were used to buffer the intermediate code.

There were 50 pages of symbol table space allocated to hold 791 non-local and 32 local symbols.

507 source lines were read in Pass 1, producing 17 object records in Pass 2.

30 pages of virtual memory were used to define 29 macros.

```
! Macro library statistics !
-----
```

## Macro library name

```
-----  
$255$DUA28:[MP.OBJ]MP.MLB;1  
$255$DUA28:[SYS.OBJ]LIB.MLB;1  
$255$DUA28:[SYSLIB]STARLET.MLB;2  
TOTALS (all libraries)
```

## Macros defined

```
-----  
4  
17  
5  
26
```

950 GETS were required to define 26 macros.

There were no errors, warnings or information messages.

MACRO/LIS=LISS:MPINT/OBJ=OBJ\$:MPINT MSRCS:MPPREFIX/UPDATE=(ENH\$:MPPREFIX)+MSRCS:MPINT/UPDATE=(ENH\$:MPINT)+EXECMLS/LIB+LIBS:MP.MLB/LI

0248 AH-BT13A-SE  
VAX/VMS V4.0

DIGITAL EQUIPMENT CORPORATION  
CONFIDENTIAL AND PROPRIETARY

MPERRLOG  
LIS

MPSCBVEC  
LIS

MPDAT  
LIS

MPPFM  
LIS

MPPWRFAIL  
LIS

MPINT  
LIS

MPMCHECK  
LIS

MPSCHED  
LIS

MPINTEXC  
LIS

MPLOG  
LIS

MPSHWPFM  
LIS

MPERRMSG  
LIS

MPLOAD  
LIS

MPINIT  
LIS